带小数点十进制转二进制的简易方法

标题略长。日前苦于理解数制的转换,心力憔悴。十进制小数点右侧第一位,代表2的-1次方,等于0.5;第二位为2的-2次方,等于0.25;以此类推,用计算机算也很慢。忽见高人一眼而止,奇之。高人云:带着例子给你讲个简单的方法吧。

// 1. 首先看小数的位数;
       13.625  
// 2. 将该数乘2的n次方;
       2的3次方为8,乘8后刚好为整数;13.625*8 = 109
// 3. 计算结果的二进制;
       109的二进制为:1101101
// 4. 添加小数点,从右往左移动相乘的位数;
       1101101 移动3位,结果为:1101.101

至于一些无论如何乘以2的n次方都无法成为整数的实数,那就意味着失真了(根据尾数长度舍弃)。实数放大数倍,取近似整数,然后转化为二进制,再添加小数点,这个步骤是一样的。

  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 原码就是一个数字的二进制表示,反码就是将原码中的每一位取反,十进制转换为二进制可以用除2取余的方法二进制转换为十进制可以用二进制的权重相加的方法。例如:十进制数10转换为二进制数1010,其原码为1010,反码为1101,二进制数11.11转换为十进制数为3.75,其原码为11.11,反码为00.00。 ### 回答2: 二进制数是计算机中最常用的数制系统,它由0和1两个数字组成。在进行二进制数的转换时,我们需要了解原码和反码的概念。 原码是二进制数的最基本表示形式,它是将十进制数直接转换为二进制的形式。例如,十进制数6在二进制中的原码是110。 反码是原码的一种特殊形式,它的计算方法是对原码的每个位进行取反操作。也就是说,0变为1,1变为0。例如,原码110的反码是001。 对于整数的二进制数,如果最高位为1,表示该数为负数。为了能够表示负数,我们需要引入补码的概念。 补码是反码加1得到的结果。例如,原码110的反码是001,补码则是010。 对于小数的二进制数,我们通常使用定点表示法。将小数点固定在某个位置,左边的部分表示整数位,右边的部分表示小数位。 在十进制和二进制之间的转换中,我们可以使用乘二取整法和除二取余法。 对于整数的转换,乘二取整法是将十进制数每次乘以2,然后将结果的整数部分作为二进制数的对应位。例如,十进制数13转换为二进制是1101。 对于小数的转换,除二取余法是将十进制数每次除以2,然后将结果的小数部分作为二进制数的对应位。例如,十进制数0.75转换为二进制是0.11。 综上所述,二进制数的原码、反码和补码表示了整数在计算机中的存储方式,而定点表示法可以用来表示小数。通过乘二取整法和除二取余法,我们可以进行十进制和二进制之间的转换。 ### 回答3: 二进制数是一种使用两个数字0和1来表示数值的计数系统。在二进制数中,每个位上的数字称为比特或二进制位。二进制数可以分为整数和小数两种类型。 对于整数二进制数,原码表示法是最简单的表示方法。该方法直接将十进制数转化为二进制数,并在最高位添加一个符号位,0表示正数,1表示负数。例如,十进制数7在原码表示法中对应的二进制数为0111,-7对应的二进制数为1111。 反码是在原码基础上的变化,用于表示负数。反码的求解方法是将原码中的符号位保持不变,其他位按位取反。例如,十进制数7对应的反码为0111,-7对应的反码为1000。 在十进制和二进制之间进行转换时,只需将每个位权上的数字进行乘法运算,并将结果相加。例如,十进制数13的二进制表示为1101,计算方法为1 * 2^3 + 1 * 2^2 + 0 * 2^1 + 1 * 2^0 = 8 + 4 + 0 + 1 = 13。同样地,二进制数1101的十进制表示为1 * 2^3 + 1 * 2^2 + 0 * 2^1 + 1 * 2^0 = 8 + 4 + 0 + 1 = 13。 对于小数二进制数,原码和反码的求解方法与整数相同。例如,十进制数0.5的二进制表示为0.1,计算方法是1 * 2^(-1) = 0.5。同样地,二进制数0.1的十进制表示为1 * 2^(-1) = 0.5。 综上所述,二进制数的原码、反码以及十进制和二进制的转换方法都是根据位权的乘法运算规则。无论是整数还是小数,通过对每个位进行权重计算并相加,可以准确地进行转换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值